<template>
  <div class="tenantMenu_main main_container">
    <div class="main_header">
      <div class="padding_container">
        <div class="left">
          <Breadcrumb />
        </div>
        <div class="right">
          <HeaderOperation :parent="this" />
        </div>
      </div>
    </div>
    <div class="main_main">
      <SearchBar :parent="this" />
      <div ref="table_container" class="table_container">
        <el-table
          ref="table"
          :data="tableData"
          stripe
          border
          :height="tableHeight"
          style="width: 99.9%"
          :cell-style="cellStyle"
          @cell-click="cellClick"
          @sort-change="(column)=>{sortChange(column, this)}"
          @selection-change="(val)=>{selectionChange(val, this)}"
        >
          <el-table-column type="selection" width="70" align="center" />
          <Column v-for="(column,index) in tableColumns" :key="index" :prop="column.prop" :is-show="column.isShow" :label="column.label" :sortable="column.sortable" :width="column.width" />

          <el-table-column label="操作" align="center" fixed="right" width="180">
            <template slot-scope="scope">
              <el-button
                v-if="scope.row.status < '1'"
                v-hasPermi="['outsource:return:edit']"
                type="text"
                @click.stop="edit(scope.row)"
              >编辑</el-button>
              <span v-else class="el-button--text button_grey">编辑</span>
              <el-button
                v-if="scope.row.status < '1'"
                v-hasPermi="['outsource:return:remove']"
                type="text"
                @click.stop="deleteOne(scope.row)"
              >删除</el-button>
              <span v-else class="el-button--text button_grey">删除</span>
            </template>
          </el-table-column>
        </el-table>
      </div>
    </div>
    <div class="main_bottom">
      <pagination
        :total="total"
        :page.sync="pageData.pageNum"
        :limit.sync="pageData.pageSize"
        :selected-num="selectionsAll.length"
        @pagination="getList"
      />
    </div>

  </div>
</template>

<script>
import { list, remove, getInfo } from '@/api/outsourceManage/outsourceReturnMaterial'
import AddOrUpdate from './addOrUpdate' // 新增或编辑页面
import ShowDetail from './ShowDetail' // 查看页面
export default {
  name: 'Index',
  data() {
    return {
      loading: true,
      pageId: '外协退料单', // 页面唯一标识
      pageData: {
        pageNum: 1,
        pageSize: 20,
        orderByColumn: 'updateTime',
        isAsc: 'desc'
      },
      total: 1, // 数据一共有多少条
      mainId: 'id', // 表格行ID
      tableHeight: '0', // 表格高度
      tableData: [], // 表格数据
      tableColumns: [], // 表格实际用的字段
      searchColumns: [], // 搜索区实际用的字段
      selections: [], // 表格当前页所选中的行
      selectionsAll: [], // 表格所有页选中的行
      defaultTableColumns: [// 表格常规字段（初始值）
        { prop: 'statusName', label: '状态' },
        { prop: 'code', label: '退料单号' },
        { prop: 'orderName', label: '退料人员', canOrder: false },
        { prop: 'materialReturnTime', label: '退料日期' },
        { prop: 'outsourceOrderCode', label: '外协订单号' },
        { prop: 'associatedDocument', label: '关联单据' },
        { prop: 'supplierName', label: '外协供应商', canOrder: false },
        { prop: 'remark', label: '备注', canOrder: false }
      ],
      defaultSearchColumns: [// 搜索区常规字段（初始值）
        { prop: 'code', label: '退料单号', type: 'input' },
        { prop: 'orderName', label: '退料人员', type: 'input' },
        { prop: 'outsourceOrderCode', label: '外协订单号', type: 'input' },
        { prop: 'associatedDocument', label: '关联单据', type: 'input' },
        { prop: 'supplierName', label: '外协供应商', type: 'input' },
        { prop: 'materialReturnTime', label: '退料日期', type: 'time' },
        { prop: 'status', label: '状态', type: 'select', optionsName: 'statusOptions' }
      ],
      statusOptions: [ // 选择组件数据源
        { value: undefined, label: '全部' },
        { value: '2', label: '已入库' },
        { value: '1', label: '待入库' },
        { value: '0', label: '待提交' },
        { value: '4', label: '已收货' }

      ],
      operationData: [ // 右上角的操作按钮
        { label: '新增', perm: 'outsource:return:add' },
        { label: '批量操作', perm: '' },
        { label: '打印', perm: 'outsource:return:list' },
        { label: '批量删除', perm: 'outsource:return:remove' },
        { label: '页面配置', perm: '' }
      ],
      showKey: {
        type: 'column_two',
        keys: [
          { type: 'form', name: '退料单号', key: 'code' }, // type: 'form' 表示是普通的表单展示
          { type: 'form', name: '退料人员', key: 'orderName' },
          { type: 'form', name: '退料日期', key: 'materialReturnTime' },
          { type: 'form', name: '外协订单号', key: 'outsourceOrderCode' },
          { type: 'form', name: '外协供应商', key: 'supplierName' },
          { type: 'form', name: '关联单据', key: 'associatedDocument' }, // length:'double' 表示占两列
          { type: 'file', name: '附件', fileName: 'fileName', fileRealName: 'fileRealName', fileUrl: 'url' },
          { type: 'Invoices', name: '入库单', key: 'enterWarehouseInvoices' },
          { type: 'form', name: '备注', key: 'remark', length: 'double' },
          {
            type: 'table', name: '', key: 'returnDetailList', columns: [ // type: 'table' 表示是表格
              { type: 'column', name: '物料编码', key: 'materialCode' }, // type: 'form' 表示是普通的表单展示
              { type: 'column', name: '物料名称', key: 'materialName' },
              { type: 'column', name: '规格型号', key: 'materialModel' },
              { type: 'column', name: '物料单位', key: 'materialUnitLabel' }
              // { type: 'column', name: '退料数量', fixed: 'right', key: 'materialReturnNumber' },
              // { type: 'column', name: '备注', key: 'remark' }
            ]
          }
        ]
      }
    }
  },
  mounted() {
    // this.$nextTick(() => {
    //   this.tableHeight = this.$refs.table_container.offsetHeight
    // })
  },
  methods: {
    cellStyle({ row, column }) {
      if (column.property == 'code') {
        return {
          cursor: 'pointer',
          color: '#387bfc'
        }
      }
    },
    cellClick(row, column, cell) {
      switch (column.property) {
        case 'code':
          this.showDetail(row)
          break
      }
    },
    showDetail(row) {
      getInfo(row.id).then(res => {
        res.data.returnDetailList = this.mergeData(res.data.returnDetailList)
        // 此处展示的页面有是否默认字段，后端给的是1，前端处理成 是
        if (res.data.returnGoodsList) {
          res.data.returnGoodsList.forEach(item => { item.isDefault == '1' ? item.isDefault = '是' : item.isDefault = '' })
        }
        this.$layer.iframe({// 弹框
          content: {
            content: ShowDetail, // 传递的组件对象
            parent: this, // 当前的vue对象
            data: {
              showData: res.data,
              showKey: this.showKey
            }// props
          },
          area: ['1320px', '700px'],
          title: '查看外协退料单', // 标题
          shadeClose: false // 点击遮罩是否关闭
        })
      })
    },
    mergeData(data) {
      const resultMap = data.reduce((result, item) => {
        const { materialId, materialReturnNumber } = item
        if (!result[materialId]) {
          result[materialId] = { ...item }
        } else {
          result[materialId].materialReturnNumber = (Number(result[materialId].materialReturnNumber) + Number(materialReturnNumber)).toString()
        }
        return result
      }, {})

      return Object.values(resultMap)
    },
    getList() {
      list(this.pageData).then(res => {
        this.tableData = res.data
        this.total = res.total
        this.tableData.forEach(item => {
          if (item.status > 0) {
            item.canNotSelectDelete = true // 不能删除的行给标记
          }
        })
        this.$nextTick(() => {
          this.setSelectRow(this)// 设置行选中
          this.tableHeight = this.$refs.table_container.offsetHeight
        })
      })
    },
    refresh() {
      this.pageData.pageNum = 1
      this.getList()
    },
    add() {
      this.$layer.iframe({// 弹框
        content: {
          content: AddOrUpdate, // 传递的组件对象
          parent: this, // 当前的vue对象
          data: {
          }// props
        },
        area: ['1320px', '700px'],
        title: '新增外协退料单', // 标题
        shadeClose: false // 点击遮罩是否关闭
      })
    },
    edit(row) {
      this.$layer.iframe({// 弹框
        content: {
          content: AddOrUpdate, // 传递的组件对象
          parent: this, // 当前的vue对象
          data: {
            id: row[this.mainId]
          }// props
        },
        area: ['1320px', '700px'],
        title: '编辑外协退料单', // 标题
        shadeClose: false // 点击遮罩是否关闭
      })
    },
    deleteOne(row) {
      const _this = this
      this.$confirm('确定要删除吗', '删除确认', {
        confirmButtonText: '确定',
        cancelButtonText: '取消', cancelButtonClass: 'cancelConfirm',
        type: 'warning'
      }).then(function() {
        remove(row[_this.mainId]).then(res => {
          _this.$message({
            message: res.msg,
            type: 'success'
          })
          _this.getList()
        })
      }).catch(() => {})
    },
    // 当前页的删除接口
    deleteMethod(deleteIds) {
      return remove(deleteIds)
    }
  }
}
</script>

<style lang="less" scoped>
</style>
